<script setup>
import Footer from "@/components/common/Footer.vue";
import {ref} from 'vue'
import {useRoute, useRouter} from 'vue-router'
import axios from 'axios'
import qs from 'qs'
// 定义响应式数据
const businessId = ref('')
const user = ref({})
const deliveryAddress = ref({
  contactName: '',
  contactSex: 1,
  contactTel: '',
  address: ''
})
const token = localStorage.getItem('token');
// 获取路由实例
const route = useRoute()
const router = useRouter()
// 从路由中获取 businessId
businessId.value = route.query.businessId

// 获取用户信息
const getUserFromSession = () => {
  const storedUser = sessionStorage.getItem('user')
  if (storedUser) {
    user.value = JSON.parse(storedUser)
  }
}

// 添加用户地址的方法
const addUserAddress = async () => {
  if (deliveryAddress.value.contactName === '') {
    alert('联系人姓名不能为空！')
    return
  }
  if (deliveryAddress.value.contactTel === '') {
    alert('联系人电话不能为空！')
    return
  }
  if (deliveryAddress.value.address === '') {
    alert('联系人地址不能为空！')
    return
  }
  deliveryAddress.value.userId = user.value.userId
  try {
    const response = await axios.post(
        'deliveryAddress/saveDeliveryAddress',
        deliveryAddress.value,
        {
          headers: {
            "Authorization": `Bearer ${token}`,
            'Content-Type': 'application/json' // 显式指定 JSON 格式
          }})
    if (response.data > 0) {
      await router.push({
        path: '/userAddress',
        query: {businessId: businessId.value}
      })
    } else {
      alert('新增地址失败！')
    }
  } catch (error) {
    console.error(error)
  }
}
// 初始化
getUserFromSession()
</script>

<template>
  <div class="wrapper">
    <!-- header部分 -->
    <header>
      <p>新增送货地址</p>
    </header>

    <!-- 表单部分 -->
    <ul class="form-box">
      <li>
        <div class="title">联系人：</div>
        <div class="content">
          <input type="text" v-model="deliveryAddress.contactName" placeholder="联系人姓名"/>
        </div>
      </li>
      <li>
        <div class="title">性别：</div>
        <div class="content" style="font-size: 3vw;">
          <input type="radio" v-model="deliveryAddress.contactSex" value="1" style="width:6vw;height:3.2vw;"/> 男
          <input type="radio" v-model="deliveryAddress.contactSex" value="0" style="width:6vw;height:3.2vw;"/> 女
        </div>
      </li>
      <li>
        <div class="title">电话：</div>
        <div class="content">
          <input type="tel" v-model="deliveryAddress.contactTel" placeholder="电话"/>
        </div>
      </li>
      <li>
        <div class="title">收货地址：</div>
        <div class="content">
          <input type="text" v-model="deliveryAddress.address" placeholder="收货地址"/>
        </div>
      </li>
    </ul>
    <div class="button-add">
      <button @click="addUserAddress">保存</button>
    </div>

    <!-- 底部菜单部分 -->
    <Footer/>
  </div>
</template>

<style scoped>
/*************** 总容器 ***************/
.wrapper {
  width: 100%;
  height: 100%;
}

/*************** header ***************/
.wrapper header {
  width: 100%;
  height: 12vw;
  background-color: #0097FF;
  display: flex;
  justify-content: space-around;
  align-items: center;
  color: #fff;
  font-size: 4.8vw;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 1000;
}

/*************** （表单信息） ***************/
.wrapper .form-box {
  width: 100%;
  margin-top: 12vw;
}

.wrapper .form-box li {
  box-sizing: border-box;
  padding: 4vw 3vw 0 3vw;
  display: flex;
}

.wrapper .form-box li .title {
  flex: 0 0 18vw;
  font-size: 3vw;
  font-weight: 700;
  color: #666;
}

.wrapper .form-box li .content {
  flex: 1;
  display: flex;
  align-items: center;
}

.wrapper .form-box li .content input {
  border: none;
  outline: none;
  width: 100%;
  height: 4vw;
  font-size: 3vw;
}

.wrapper .button-add {
  box-sizing: border-box;
  padding: 4vw 3vw 0 3vw;
}

.wrapper .button-add button {
  width: 100%;
  height: 10vw;
  font-size: 3.8vw;
  font-weight: 700;
  border: none;
  outline: none;
  border-radius: 4px;
  color: #fff;
  background-color: #38CA73;
}
</style>